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(54) Network printer with remote print queue control procedure 

(57) The method of the invention enables remote" 
control of a print queue (28) in a network printer (14) 
which receives print jobs over the Internet from plural 
client processors (10,12). The network printer (14) • 
includes a server procedure (24) which enables transfer 
of files from the network printer (14) over the network 
and a browser procedure (26) which enables retrieval of 
files from client processors (10,12) over the network. 
The method includes the steps of: establishing a queue 
(28) of received print job identifiers; employing the 
server procedure (24) to provide a first file to a client 
processor (10,12) to enable the client processor (10.12) 
to transmit a status request concerning the print queue; 
receiving a message including the status request and 
transmitting, in response, a second file with queue data 
to the client processor (10.12). the second file further 
including queue alteration choices; receiving a 
response message from the client processor (10,12) 
with at least one queue alteration value; and altering the 
queue (28) accordingly. The method further includes the 
step of responding to a received URL from a scanner 
(16). by employing the browser procedure (26) to 
retrieve a text file identified by the URL. 
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Description 

FIELD OF THE INVENTION 

This invention relates to printers that are particu- 
larly adapted to being connected to an Internet port 
and, more particularly, to a network printer which 
includes procedures that enable remote client proces- 
sors to control print jobs that are queued for printing on 
the network printer. 

BACKGROUND OF THE INVENTION , 

The Internet and its ' associated worldwide web 
(WWW) are well-known and established communication 
networks; • Increasingly business applications are 
employing the- worldwide web to transfer print jobs from 
client processors to network printers that are remotely 
located. A significant feature of the worldwide web is 
that it offers a common interface which enables comput- 
ing devices that are controlled by different operating 
system platforms to communicate and to be understood 
by each other. This communication capability arises as 
a result of each of the operating system platforms hav- 
ing program modules which enable the devices to com- 
municate via the -common messaging protocol used 
over the worldwide web. 

That protocol is termed the "HyperText. Transfer , 
Protocol" or HTTP. HTTP provides a way for WWW cli- 
ents and servers to communicate, primarily through the 
exchange of messages that are brief and direct. HTTP 
employs specific message categories, i.e.: a "connec- 
tion"; a "request"; a "response" and a "close". A connec- 
tion is a message which occurs as a client tries to 
connect to a specific web server. As will be understood 
from the description below, a network printer which 
incorporates the invention operates as a web server 
and is accessed by client processors. 

A request is when a client processor asks for a web 
resource it is looking for. Such request includes the pro- 
tocol to be used, the name of the object being sought 
(i.e. its universal resource locator or URL), and informa- 
tion about how the server should respond to the client 
processor. 

A response is a server's message which responds 
in the manner requested by the client processor and v . 
delivers the requested data. A close occurs after the 
information has been transferred in response to the. 
request. The connection can then be reopened with : . 
another request, for example, by clicking on a link in a . 
current web page. 

• An Internet printing system, recently announced by , 
the Pipeline Corporation (see "The Hard-Copy 
Observer", pages 45. 46, March 1997), describes a net- . 
work printer that includes functions which enable a URL 
of a print job to be received. The printer's home page 
includes a field that allows a. user to enter URLs of 
desired pages to be printed: The printer, includes sched- 


uling software which allows a user to program the 
printer to periodically access a prescribed list of web 
sites and to automatically print the pages it finds there. 
The system also enables.the printer to be programmed 
5 to retrieve and print pages that are hyperlinked to an 
original document, down a specified number of link lev- 
els. 

Because many client processors can access net- 
. work printers over the worldwide web, such a printer 
.w must have an ability- to establish a queue for received 
- print jobs so as to enable such print jobs to be handled 
in an orderly manner. It is desirable, however, that client 
. processors have an .ability to view the printer's print 
. . queue and, to access information regarding the status 
is of each print job on the print queue. Further it is desira- 
ble that a client processor have an ability, if authorized, 
• to alterthe print-queue. Such a capability will enable the 
print queue to be a "universal queue" that is accessible 
_ . • by .any number of client processors and will enable each 
20 client processor to render an informed decision regard- 
.. r- ing whether it wishes to use the particular network 
printer. AJso, the capability will provide an ability to 
remotely modify the print queue, in accordance with 
preassigned priority client queue management rights. 
25 Accordingly, it is an object of this invention to pro- 
vide a ; network printer with a capability to - establish a 
. universal print queue. 

It is another object of this invention to provide a net- 
work printer with an ability to report print queue status 
30 data to client processors. 

It is yet another object of this invention to provide a 
network printer with an ability, to.respond to HTTP-con- 
figured messages and to both report print queue status 
and to retrieve print jobs in response thereto. 
35 It is yet another object of this invention to enable a 
scanner device attached to the WWW to provide a URL 
indicator to a printer and for the printer.to respond by 
accessing a scanned image. 

40 . SUMMARY OF THE INVENTION . 

The method of the invention enables remote control 
of a print queue in a network printer which receives print 
jobs over the Internet from plural client processors. The 

45 network printer includes a server procedure which ena- 
- bles transfer of files from the network printer over the 
network and a browser procedure which enables 
retrieval of files from client processors over the network. 
The method includes the steps of:, establishing a queue 

so of received print job. identifiers; employing the server 
procedure to provide a first file to a client processor to 
enable the client processor to transmit a status request 
concerning the print queue; receiving a message 
including the status request and . transmitting, in 

55 response, a second file with queue data to the client 
processor, the second file further including queue alter- 
ation choices; receiving a response message from the 

. ^. client, processor. r with. at least one queue alteration 
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value; and altering the queue accordingly. The method 
further includes the step of responding to a received 
URL from a scanner, by employing the browser proce- 
dure to retrieve a print job from the scanner that is iden- 
tified by the URL. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. Vis a schematic system diagram illustrating the 
relationship of a printer incorporating the invention to 
plural client processors and a scanner, all of which com- 
municate over the WWW. ; • v : 

*" Fig. 2 illustrates a home page provided by the 
printer of Fig. 1 . in response to a message from a client 
processor. 

Fig. 3 is a further printer web page illustrating a 
queue of print jobs awaiting printing in~the printer of Fig. 
1. . ., 

; * Fig. 4 "is a further printer web page 1 illustrating job 
detail of any selected job listed in the -print queue of Fig. 
3. and further showing various queue alteration actions 
which are available to a client processor : "~ 

DETAILED DESCRIPTION OF THE INVENTION 

Turning to Fig. 1. plural client processors 10. 12... 
etc. are coupled to the WWW and are thus able to com- 
municate with a network printer 14. A scanner 16 is also 
coupled to the WWW and communicates with network 
printer 14. Each client processor (i.e., 10. 12....) 
includes a browser procedure 18 and a server proce- 
dure 20. Scanner 16 includes only a server procedure 
20. Further, each client processor includes an applica- 
tion 22 which may have a print job ready for submission 
to printer 14. A client processor (e.g.. 12) may wish to 
have a print job 23 that is present in another client proc- 
essor (e.g., 10) submitted to printer 14 for printing. In 
the alternative, a user at a client processor may wish to 
view the status of print jobs queued on printer 14 and to 
alter the queue status of one or more such print jobs. 

Accordingly, printer 14 is also provided with a 
server procedure 24 and a browser procedure 26. 
Server procedure 24 provides a print job management 
function for printer 14 and is further used to respond to 
request messages from one or more client processors. 
Browser procedure 26 enables printer 14 to respond to 
a received URL by accessing, via the WWW. the print 
job designated by the URL. The URL may designate a 
print job residing at any client, whether it is the client 
which originated the message with the URL or any other 
client. The responses transmitted by browser 26 are for- 
matted in a formatter module 30. using the HTML or any 
other formatting procedure. 

Printer 14 further includes a job queue 28 which 
lists the URL's of received print jobs. Upon a URL being 
reached on job queue 28. printer 14 causes browser 26 
to transmit a request to the client processor wherein the 
specific print job corresponding to the" URL- is located. 


The client processor then responds with the text of the 
print job. which text is then printed by printer 14. 

Job queue 28 is managed by a queue manager 32 
which maintains status data and controls the position of 
5 each of the URLs listed on job queue 28. Queue man- 
ager 32 is further enabled to rearrange the listed URLs 
in accordance with received commands that appear on 
a web page transmitted from a client processor. 

Server procedure 24 maintains a "home page" 
10 which is shown in Fig. 2. The home page is the default 
page which is transmitted by server 24 to an inquiring 
client processor that has transmitted a request to printer 
1 4. The home page provides data regarding the proper- 
• ties of printer 14. such as its WWW address, capabili- 
15 ties, whether it is on-line, etc.- The home page also 
provides further virtual buttons 40-44 which enable a 
linking to other pages and provide a capability to cause 
v" v the printer to: respond with: its properties: (button 40); 
cf-come on-line (button 41); provide a listing of jobs that 
so.}' are present on job queue 28 (button 42); provide a diag- 
nostic procedure for. remotely diagnosing a problem 
. - within printer 14 (button 43); and provide further config- 
uration information (button 44). 

Upon receiving the home page from printer 14. a 
25 » user at a client processor may wish to view the jobs that 
. are presently listed on job queue 28. To obtain a web 
page illustrating the jobs queued on job. queue 28. the 
user clicks on job's button 41 which causes a request 
message to be transmitted back to printer ; 14, with a 
30 code indicating a request to provide the» "job's list" page 
shown in Fig. 3. 

-The job's list page includes an identifier for each job 
(e.g.. the job's URL); a description of the job; the status 
of the job (i.e.. is it printing, printed, queued, etc.) and 

- 35 the owner of the job. At the bottom of the job s list page 

is a virtual button 50 which enables the user at the client 
processor to access further printer pages. If virtual 
"select job" button 50 is selected by a mouse click and 
then a cursor is placed at a job entry, followed by a 
40 mouse click, a "job detail" page is produced. 

• More specifically, upon a user at a client processor 
selecting a particular job in the job's list page, a request 
message is sent to. printer 14 which is received by 
server 24. Server 24, in turn, queries queue manager 

- 45 32 for details of the selected job. A job detail page is 

then constructed, as shown in Fig. 4. with details of the 
selected job. The job detail page is then dispatched as 
" a response message to the originating client processor. 
The job detail page enables the originating client 
so processor to exert control over job queue 28 and the 
details of the specific job shown in the received job 
detail page. More specifically, by clicking one of the 
entries on the job detail page, an entry can be high- 
lighted and altered. Thus, as shown in Fig. 4, not only is 
55 the identity of the job indicated, but its state; the number 
of pages printed; the URL of the job; the job description; 
e - the owner; and the number of copies required. At the 
■ > bottom of the job detail page are a number of virtual but- 
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tons which enable a job entry parameter to be altered. 

Change button 60 enables the alteration of a high- 
lighted field on the page that has been previously 
selected by the user at the client processor. For 
instance, if it is desired to change the. number of copies, 
the "copies" line is highlighted, followed by a clicking on 
"change" button 60. after which the number of copies 
can be altered. Change button 60 may also be used to 
modify the queue position of a job listed on job queue 
28. To accomplish such a unilateral change in position, 
the client processor must have been previously pro- 
vided with an assigned priority level which enables its 
print jobs to enjoy a higher priority status than other 
print jobs on job queue 28 that are to.be "pushed down" 
in favor of the client processor's print job. In .such case, 
change button 60 enables a print job from the higher pri- 
ority client processor to be repositioned on job queue 28 ' 
to a position just prior to a print job of equal or higher pri- 
ority, as the case may be. 

By clicking on "cancel" button 62, a selected job can 
be canceled in its entirety . By clicking on "hold" button 
64, the position on job queue 28 of a.selected job will 
not be advanced, notwithstanding the completion of 
jobs higher up on the queue. The clicking of "resume" "* 
button 66 negates the hold status and enables a contin- 
ued movement of the print job on job queue 28. "Add" 
button 68 enables a message to be sent to printer 1 4 to 
provide a blank "Printer job detail" page, which will ena- 
ble a new job to be entered by the user. 

Buttons 70 and 72 enable messages to be transmit- 
ted to printer 14 to cause a re-transmission of either a 
last transmitted web page or the printer's home page. 

Returning to Fig. 1 , scanner 1 6 is also provided with 
a server procedure 20 which enables scanner 16 to 
transmit a URL of a scanned document text file to a 
printer 14. Such transmission occurs after scanner 16 
has scanned and stored a document and the document 
is now to be printed. Upon receiving the URL, printer 1 4 
causes browser procedure 26 to transmit a request 
message to scanner 1 6 which requests that the text file 
be appended to the response message and re-transmit- 
ted back to printer 14. Accordingly, scanner 16 formats 
the response page from printer 14 by appending the 
scanned document text file and transmitting the page 
and text file to printer 14 for printing. Accordingly, printer < 
14 executes a file "pull" action upon the data stored in 
scanner 16, thereby enabling the text file to be down- 
loaded to printer 14 and eventually printed. 

While the procedures which control printer 14, i.e.. 
server procedure 24. browser procedure 26, formatter f 
procedure 30 and print queue manager 32 have been 
described as already having been loaded onto printer 
14, one skilled in the art will realize that such proce- 
dures are initially loaded by insertion of one or more ; 
memory disks 80 (Fig. 1) into a disk drive read/write ~'~s 
assembly (not shown) associated with printer 14. 
Accordingly, the invention encompasses not only the 
above-described software procedures when incorpo- 


rated into printer 14, but also when such procedures are 
incorporated onto "a magnetic disk which is used to con- 
trol various instrumentalities within printer 14. 

It should be understood that the foregoing descrip- 
tion is only illustrative of the invention". Various alterna- 
tives and modifications can be devised by those skilled 
in the art without departing from the invention. Accord- 
ingly, the present invention is intended to embrace all 
such alternatives, modifications and variances which fall 
within the scope of the appended claims. 


Claims 


1. A method >or enabling control of a network printer 
(14) which receives print jobs over a network from 

' plural client processors (10,12), said network 
printer (14) including a server procedure (24) for 
enabling transfer of files from said network printer 
(14) over said network and a browser procedure 
(26) for enabling retrieval of files to said network 
printer (14) over said network, said method com- 
prising the steps of : • 

a) establishing a queue (28) of received print 
job identifiers; 

b) employing said server procedure (24) to pro- 
_ vide a first file to a client processor (10.12) to 

enable said client processor (10,12) to transmit 
a status'message concerning said queue (28); 

c) receiving said status message and enabling 
said server procedure (24) to transmit a 
response'comprising a second file with queue 
data to said client processor (10.12), said sec- 
ond file further including queue alteration 
choices; and 

d) receiving a further response message from 
said client processor (10, 12) with at least one 
queue alteration value and altering said queue 
(28) accordingly. 

2. The method as recited in claim 1 , wherein said fur- 
ther response message includes an identifier of a 
print job (23), said method comprising the added 
step of: 

e) employing said browser procedure (26) to 
retrieve said print job (23). ; 

3. The method as recited in claim 1 . wherein said fur- 
ther response message comprises a list of print 
jobs on said queue (28) and status indications for 
each said print job. 

4. The method as recited in claim 1 . wherein said sta- 
tus indications comprise at least one of: printing 
status, print job owner, order of jobs to print and 
expected time to print. 


4 


7 


EP 0 886 206 A2 


8 


5. . The method as recited in claim 1 , wherein said sta- 

tus indications comprise at least one of: printing 
status, print job owner, order of jobs to print and 
expected time to print. 

6. The method as recited in claim 1 . wherein said first 
: . file and second file are Web pages that are conf ig- 

.ured in accordance with a HyperText Markup Lan- 
guage. ... ...... 

7. The method as recited in claim 1 , wherein said first 
file and second file are each identified by a Univer- 
sal Resource Locator identifier. 

8. The method as recited in claim 1. wherein said 
server procedure (24) arid browser procedure (26) 
operate in accordance" with a Hypertext Transfer 
Protocol. . 

9. ; ,A memory media (80). including procedures for con- 

trolling a network printer (14) which receives print" 
jobs over a network from plural ciient processors 
(10.12). said network printer (14) including a server 
procedure (24) for enabling transfer of files from 
said network printer (14) over said, network and a 
browser procedure (26) for enabling retrieval of files 
to said network printer (14) over said network, said 
memory media (80) comprising: 

a) means for controlling said network printer 
(14) to establish. a queue (28), of received print 
job identifiers; „ . 

b) means for controlling said network printer 
(14) to employ said server procedure (24) to . 
provide a first file to a client processor (10,12) 
to enable said client processor (10.12) to trans- 
mit a status message concerning said queue 

(28); ' '.; 

c) means for controlling said network printer 
(14) to receive said status message and to < 
enable said server procedure (24) to transmit a 
response comprising a second file with queue 
data to said client processor (10,12). said sec- 
ond file further including queue alteration 
choices; and . 

d) means for controlling said network printer 
(14) to receive a further response message 
from said client processor (10.12) with at least 
one queue alteration value and to alter said . . 
queue (28) accordingly. . 

10. The memory media (80) as recited in claim 9, 
wherein said further response message includes . 
an identifier of a print job. said memory media (80) 
further comprising: . 

e) means for controlling said network printer 
(14) to employ said browser procedure (26) to 


retrieve said print job. 

11. The memory media (80) as recited in claim 9. 
wherein said further response message comprises 

5 a list of print jobs on said queue (28) and status 

indications for each said print job. 

12. The memory "media (80) as recited in claim 9. 
wherein said status indications comprise at least 

w one of: printing status, print job owner, order of jobs 
to print and expected time to print. 

13. The memory media (80) as recited in claim 9, 
wherein said queue alteration choices for print jobs 

Ys . listed on said queue (28) comprise at least one of: 
deleting a print' job, reordering a print job. delaying 
?; a print * job. : resuming 1 a print job and changing 
attributes of a print job. 

'20 '-' 14. The : memory media (80) as ' recited in claim 9, 
: ' : " wherein said first file and second file are Web 
pages' that are configured in accordance with a 
'*"'■ Hypertext Markup Language. 

25 15. The memory media (80) as recited in claim 9. 
wherein said first file and secondf ile'are each iden- 
tified by a Universal Resource Locator identifier. 

16. The memory media (80) as recited in claim 9, 
36 wherein said server procedure (24) and browser 

procedure (26) operate in accordance with a Hyper- 
text Transfer Protocol. 

17. A method for enabling control of a network printer 
35 (14) which receives print jobs over a network from a 

document scanner (16), said document scanner 
(16) including a server procedure (20) for enabling 
transfer of a Universal Resource Locator (URL) 
over said network , said network printer (14) includ- 
40 ing a browser procedure (26) for enabling retrieval 
of files to said network printer (14) over said net- 
work, said method comprising the steps of: 

a) Receiving a URL designating a scanned 
45 document file from said document scanner 

(16); 

b) employing said browser procedure (26) to 
provide a Web page to said document scanner 
(16) to enable said document scanner (16) to 

so configure and transmit a response which 

includes said scanned document file; and 

c) receiving said response with said scanned 
~ document file and printing text from said 

scanned document file. 


5 


EP 0 886 206 A2 


CLIENT 
PROCESSOR 


UN|X_ - 

SERVER PROCEDURE' 


PRINT JOB^ 


-10 


CLIENT PROCESSOR 

y-Tl /- 18 


APPLICATION 

1 8R0WSER 
(HTTP) 

(PRINT JOB) 





SERVER 
" "(HTTP) 

^-20 

(WINDOWS) 


80 


PRINTER 


SERVER 
(HTTP) 


SCANNER 
SERVER PROCEDURE 


-24 


JOB QUEUE 


-28 


FIG.1 


14 


QUEUE 
MANAGER 


BROWSER 
(HTTP) 


-16 
-20 




32 


26 


-30 


FORMATTER 
(HTML) 


6 


EP 0 886 206 A2 


PRINTER HOME PAGE 


PRINTER TYPE: 
ADDRESS: 

CAPABILITIES: 
ppm: 

CONTRA LANGUAGE: 
MEMORY: 


FIG.2 


PROPERTIES 


V/////////A 


ONLINE 


JOBS 


DIAGNOSTIC 


CONFIG. 


•40 


41 


42 


•43 


44 


PRINTER JOBS LIST 


JD 
10 
11 
15 
20 


DESCRIPTION 
SPREAD SHEET 
LETTER 
DOCUMENT X 
DOCUMENT Y 


STATUS 

PRINTED 

PRINTING 

QUEUED 

QUEUED 


OWNER 

STEVE 

JEFF 

SAM 

ROB 


SELECT 
JOB 


-50 


FIG.3 


7 


EP 0 886 206 A2 


PRINTER JOB DETAIL 
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